<template>
    <div>
        <!--:model="shop" 数据双向绑定-->
        <!--ref="shopForm" id="shopForm",给form去一个名字-->
        <!--:rules="formRules" 校验规则-->
        <el-form :model="shop" ref="shopForm" :rules="formRules" label-position="left" label-width="100px" class="demo-ruleForm login-container">
            <el-row :gutter="50">
                <el-col :span="12">
                    <h3>店铺入驻</h3>
                    <el-form-item prop="name"label="名称">
                        <el-input type="text" v-model="shop.name" auto-complete="off" placeholder="请输入店铺名称！"></el-input>
                    </el-form-item>
                    <el-form-item prop="tel" label="座机">
                        <el-input type="text" v-model="shop.tel" auto-complete="off" placeholder="请输入座机！"></el-input>
                    </el-form-item>
                    <el-form-item prop="address" label="店铺地址">
                        <el-input type="text" style="width: 350px" v-model="shop.address" auto-complete="off" placeholder="请输入地址！"></el-input>
                        <el-button size="small" type="primary" @click="selectAdrress">选择</el-button>
                    </el-form-item>
                    <el-form-item prop="logo" label="店铺Logo">
                        <el-upload
                                class="upload-demo"
                                action="http://172.16.80.248:8080/fastdfs/upload"
                                :on-preview="handlePreview"
                                :on-remove="handleRemove"
                                :on-success="handleSuccess"
                                :file-list="fileList"
                                list-type="picture">
                            <el-button size="small" type="primary" style="width: 100px;height: 29px;">点击上传</el-button>
                            <div slot="tip" class="el-upload__tip">只能上传jpg/png文件，且不超过500kb</div>
                        </el-upload>
                    </el-form-item>
                </el-col>
                <el-col :span="12">
                    <h3>管理员信息设置</h3>
                    <el-form-item prop="username" label="账号">
                        <el-input type="text" v-model="shop.username" auto-complete="off" placeholder="请输入账号！"></el-input>
                    </el-form-item>
                    <el-form-item prop="phone" label="手机号码">
                        <el-input type="text" v-model="shop.phone" auto-complete="off" placeholder="请输入电话！"></el-input>
                    </el-form-item>
                    <el-form-item prop="email" label="电子邮件">
                        <el-input type="text" v-model="shop.email" auto-complete="off" placeholder="请输入邮件！"></el-input>
                    </el-form-item>
                    <el-form-item prop="password" label="密码">
                        <el-input type="password" v-model="shop.password" auto-complete="off" placeholder="请输入密码！"></el-input>
                    </el-form-item>
                    <el-form-item prop="comfirmPassword" label="确认密码">
                        <el-input type="password" v-model="shop.comfirmPassword" auto-complete="off" placeholder="请输入确认密码！"></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-form-item style="width:100%;">
                <el-button type="primary" style="width:100%;" @click.native.prevent="settledIn" >入驻</el-button>
            </el-form-item>
        </el-form>
        <el-dialog
                title="选择地址"
                :visible.sync="dialogVisable"
                width="30%">
                <baidu-map OverviewMapControl="true"
                           :center="{lng: 116.403765, lat: 39.914850}"
                           :scroll-wheel-zoom="true"
                           :zoom="11">
                    <bm-control :offset="{width: '10px', height: '10px'}">
                        <!--:sugStyle="{zIndex: 2100} 让搜索提示上浮-->
                        <bm-auto-complete v-model="keyword"  :sugStyle="{zIndex: 2100}">
                            <div style="margin-bottom:30px" >
                                <input id="searchInput" type="text" placeholder="请输入关键字" class="searchinput"/>
                                <el-button type="success" @click="selectAdrressConfirm">确定</el-button>
                            </div>
                        </bm-auto-complete>
                    </bm-control>
                    <bm-view class="map"></bm-view>
                    <bm-map-type :map-types="['BMAP_NORMAL_MAP', 'BMAP_HYBRID_MAP']" anchor="BMAP_ANCHOR_BOTTOM_RIGHT"/>
                    <bm-local-search :keyword="keyword" :auto-viewport="true" style="width:0px;height:0px;overflow: hidden;"></bm-local-search>
                </baidu-map>
                <span slot="footer" class="dialog-footer">
                    <el-button @click="dialogVisable=false">取 消</el-button>
                    <el-button type="primary" @click="dialogVisable=false">确 定</el-button>
                </span>
        </el-dialog>
    </div>
</template>

<script>
    export default {
        data() {
            var validatePass2 = (rule, value, callback) => {
                console.log(value); //确认密码
                if (value === '') {
                    callback(new Error('请再次输入密码'))
                } else if (value !== this.shop.password) {
                    callback(new Error('两次输入密码不一致!'))
                } else {
                    callback()
                }
            };
            return {
                keyword:'',
                dialogVisable:false,
                fileList: [],
                //shop:shop 为了做数据表单校验不要嵌套对象
                shop: {
                    name: '',
                    tel: '',
                    address: '',
                    logo: '',
                    username: '',
                    phone: '',
                    email: '',
                    password: '',
                    comfirmPassword: ''
                },
                formRules: {
                    name: [
                        { required: true, message: '请输入店铺名称!', trigger: 'blur' }
                    ],
                    tel: [
                        { required: true, message: '请输入店铺座机!', trigger: 'blur' }
                    ],
                    address: [
                        { required: true, message: '请输入店铺地址!', trigger: 'blur' }
                    ],
                    // logo: [
                    //     { required: true, message: '请输入店铺logo!', trigger: 'blur' }
                    // ],
                    username: [
                        { required: true, message: '请输入账号!', trigger: 'blur' }
                    ],
                    phone: [
                        { required: true, message: '请输入手机号!', trigger: 'blur' }
                    ],
                    email: [
                        { type: 'email',required: true, message: '请输入邮箱!', trigger: 'blur' }
                    ],
                    password: [
                        { required: true, message: '请输入密码!', trigger: 'blur' }
                    ],
                    comfirmPassword: [
                        {required: true,validator: validatePass2, trigger: 'blur' } //自定义校验规则
                    ]
                }
            };
        },
        methods: {
            selectAdrressConfirm(){
                //获取值搜索框值,设置给地址
                var searchInputV=document.getElementById("searchInput").value;
                this.shop.address = searchInputV;
                //关闭对话框
                this.dialogVisable = false;
            },
            selectAdrress(){
                this.dialogVisable = true;
            },
            handleSuccess(response, file, fileList){
                console.log("===========")
                console.log(response);
                console.log(file);
                console.log(fileList);
                this.shop.logo = response.data;
            },
            handleRemove(file, fileList) {
                var arr = this.shop.logo.split("/");
                var filename = this.shop.logo.substring(this.shop.logo.indexOf("/")+1).substring(this.shop.logo.indexOf("/"));
                console.log(arr[1],filename);
                let para = {
                    group:arr[1],
                    filename:filename
                };
                this.$http.delete("/fastdfs/delete",para)
                    .then(res=>{
                        if(res.data.success){
                            this.$message({
                                message: '删除成功!',
                                type: 'success'
                            });
                        }else{
                            this.$message({
                                message: '删除失败!',
                                type: 'error'
                            });
                        }
                    })
            },
            handlePreview(file) {
                console.log(file);
            },
            settledIn(){
                this.$refs.shopForm.validate((valid) => {
                    //校验表单成功后才做一下操作
                    if (valid) {
                        this.$confirm('确认入驻吗？', '提示', {}).then(() => {
                            //拷贝后面对象的值到新对象,防止后面代码改动引起模型变化
                            let para = Object.assign({}, this.shop); //shop 本身这个参数里面就有店铺和管理员信息
                            // 为了后台好接收，封装一个对象放到里面
                            let admin = {
                                username: para.username,
                                phone: para.phone,
                                email: para.email,
                                password:para.password,
                                comfirmPassword:para.comfirmPassword
                            }
                            para.admin = admin;
                            //判断是否有id有就是修改,否则就是添加
                            this.$http.post("/lr/settledIn",para).then((res) => {
                                if(res.data.success){

                                    alert("提交成功，请耐心等待平台审核！");
                                    location.href='http://localhost/index.html'
                                }
                                else{
                                    alert("提交失败，请重新填写信息！");
                                }

                            });
                        });
                    }
                })
            },
            reSettleIn(){
                var url = window.location.href;
                var id= url.split("?")[1].split("=")[1];
                this.$http.get("/lr/reSettleIn/"+id)
                    .then(res=>{
                        res = res.data;
                        if (res.success){
                            res = res.data;
                            this.shop.name=res.name;
                            this.shop.tel=res.tel;
                            this.shop.address = res.address;
                            this.shop.logo=res.logo;
                            this.fileList=[
                                {
                                    name:'',
                                    url:'http://121.37.194.36'+res.logo
                                }
                            ];
                            this.shop.username=res.admin.username;
                            this.shop.phone=res.admin.phone;
                            this.shop.email=res.admin.email;
                            /*this.fileList.push({
                                name:'photo.jpg',
                                url:'http://121.37.194.36'+this.shop.logo
                            })*/
                        }else {
                            alert("加载失败！")
                        }
                    })

            }
        },
        mounted(){
            this.reSettleIn();
        }
    }

</script>

<style lang="scss" scoped>
    .login-container {
        -webkit-border-radius: 5px;
        border-radius: 5px;
        -moz-border-radius: 5px;
        background-clip: padding-box;
        margin: 50px auto;
        width: 1000px;
        padding: 35px 35px 15px 35px;
        background: #fff;
        border: 1px solid #eaeaea;
        box-shadow: 0 0 25px #cac6c6;
        .title {
            margin: 0px auto 40px auto;
            text-align: center;
            color: #505458;
        }
        .remember {
            margin: 0px 0px 35px 0px;
        }
    }
    .map {
        width: 100%;
        height: 300px;
    }
    .searchinput{
        width: 300px;
        box-sizing: border-box;
        padding: 9px;
        border: 1px solid #dddee1;
        line-height: 20px;
        font-size: 16px;
        height: 38px;
        color: #333;
        position: relative;
        border-radius: 4px;
    }
    .upload-demo{
        width: 400px;
    }
</style>